home *** CD-ROM | disk | FTP | other *** search
/ Amiga Plus Special 24 / AMIGAplus Sonderheft 24 (2000)(Falke)(DE)[!].iso / PublicDomain / Anwendungen / MT-RechnungIII / Rexx / WWAngebot.outrexx < prev    next >
Text File  |  1998-11-16  |  11KB  |  492 lines

  1. /*
  2. ** Druck-, Vorschau, Sichern des Angebots mit Hilfe von WordWorth
  3. ** $VER: WWAngebot.outrexx V1.03 (17.11.98)
  4. */
  5.  
  6. PARSE ARG ARexxPort;
  7.  
  8. ADDRESS VALUE ARexxPort;
  9. OPTIONS RESULTS;
  10.  
  11. WWVorlage    = "WWDokumente/Angebot.ww";
  12. WWDokument    = "t:Angebot.ww";
  13. WWPort        = "WORDWORTH."
  14.  
  15. LF                    = '0a'x;                            /* Zeilenvorschub                */
  16.  
  17. Gefunden = 0;
  18. DO i = 1 TO 20 WHILE(Gefunden = 0)
  19.     IF show(ports, (WWPort || i)) THEN
  20.         DO;
  21.             Gefunden = 1;
  22.             WWPort = WWPort || i;
  23.         END;
  24. END;
  25.  
  26. IF Gefunden = 0 THEN
  27.     DO;
  28.         ES_TITLE                = "Warnung";
  29.         ES_TEXTFORMAT        = "WordWorth ist nicht aktiv, bitte starten sie dieses" || LF || "und versuchen Sie es erneut";
  30.         ES_GADGETFORMAT    = "Abbrechen";
  31.         EASY_REQUEST;
  32.         EXIT;
  33.     END;
  34.  
  35. /* Original WW-Dokument nach t: kopieren, um ein versehentliches überschreiben */
  36. /* dieser Vorlage zu verhindern */
  37. GET_REXXPATH;
  38. WWVorlage        = MTR_RESULT || WWVorlage;
  39. ADDRESS COMMAND "copy" WWVorlage WWDokument;
  40.  
  41. /* Oberfläche sperren */
  42. LOCKGUI;
  43.  
  44. /* Art ermitteln: 0 = Drucken, 1 = Vorschau, 2 = Speichern */
  45. PRINTSTATE;
  46. Druckart = MTR_RESULT;
  47.  
  48. Ende_Kennzeichen = 'N';
  49.  
  50. /* Suchen der zu druckenden Daten */
  51. GET_PREFS;
  52. PRINTFIND;
  53.  
  54. /* Neues Dokument öffnen */
  55. ADDRESS VALUE WWPort;
  56. NEW;
  57. WWPort = RESULT;
  58.  
  59. DO WHILE( MTR_RESULT > 0 & Ende_Kennzeichen = 'N');
  60.  
  61.     CALL DatenAufbereiten;
  62.     SELECT;
  63.         WHEN Druckart = 0 THEN    /* Drucken    */
  64.             DO;
  65.                 ADDRESS VALUE WWPort;
  66.                 PRINT;
  67.                 ADDRESS VALUE ARexxPort;
  68.                 MTSCREENTOFRONT;
  69.             END;
  70.         WHEN Druckart = 1 THEN    /* Vorschau    */
  71.             ADDRESS VALUE ARexxPort;
  72.         WHEN Druckart = 2 THEN    /* Sichern    */
  73.             DO;
  74.                 ADDRESS VALUE WWPort;
  75.                 SAVEAS;
  76.                 ADDRESS VALUE ARexxPort;
  77.                 MTSCREENTOFRONT;
  78.             END;
  79.         OTHERWISE
  80.             DO;
  81.                 ES_TITLE                = "Warnung";
  82.                 ES_TEXTFORMAT        = "Druckart wird nicht unterstützt!";
  83.                 ES_GADGETFORMAT    = "Ok";
  84.                 EASY_REQUEST;
  85.                 Ende_Kennzeichen    = 'J';
  86.             END;
  87.     END;
  88.  
  89.     PRINTFIND;
  90. END;
  91.  
  92. /* WordWorth-Datei aus t: wieder entfernen */
  93. ADDRESS COMMAND "delete" WWDokument;
  94.  
  95. /* Oberfläche wieder entsperren */
  96. ADDRESS VALUE ARexxPort;
  97. FREEGUI;
  98.  
  99. EXIT;
  100.  
  101. DatenAufbereiten:
  102.  
  103.     ADDRESS VALUE ARexxPort;
  104.  
  105.     IF PREFS.NUMBER_DIGITS > 0 THEN
  106.         DO;
  107.             ZW_Rechnung = RIGHT( (Copies("0",PREFS.NUMBER_DIGITS) || MTR_RESULT), PREFS.NUMBER_DIGITS );
  108.             ZW_Kunde = RIGHT( (Copies("0",PREFS.NUMBER_DIGITS) || OB.INVOICEE_NUMBER), PREFS.NUMBER_DIGITS );
  109.         END;
  110.     ELSE
  111.         DO;
  112.             ZW_Rechnung = MTR_RESULT;
  113.             ZW_Kunde = OB.INVOICEE_NUMBER;
  114.         END;
  115.     IF PREFS.CLIENT_CODE = 1 THEN
  116.         ZW_Kunde    = OB.INVOICEE.CUSTOMER.CLIENT_CODE;
  117.  
  118.     FORMAT_DATE_LONG date(s);
  119.     PRINTDATE = MTR_RESULT;
  120.  
  121.     FORMAT_DATE_LONG OB.DATE_TENDER;
  122.     TENDER_DATE_LONG = MTR_RESULT;
  123.  
  124.     w = OB.CURRENCY_USED;
  125.     IF w < 2 THEN
  126.         FORMAT_MONEY1 OB.TOTAL_M_ALL_CH.w;
  127.     ELSE
  128.         FORMAT_MONEY2 OB.TOTAL_M_ALL_CH.w;
  129.     ZW_Betrag    = MTR_RESULT;
  130.  
  131.     IF w < 2 THEN
  132.         FORMAT_MONEY1 OB.DISPATCH_COSTS.w;
  133.     ELSE
  134.         FORMAT_MONEY2 OB.DISPATCH_COSTS.w;
  135.     ZW_Versand    = MTR_RESULT;
  136.  
  137.     FORMAT_NUMBER OB.DISCOUNT_PERCENT PREFS.FRAC_DIGITS_PERCENT;
  138.     DISP    = MTR_RESULT;
  139.  
  140.     IF w < 2 THEN
  141.         FORMAT_MONEY1 OB.DISCOUNT.w;
  142.     ELSE
  143.         FORMAT_MONEY2 OB.DISCOUNT.w;
  144.     DIS    = MTR_RESULT;
  145.  
  146.     IF w < 2 THEN
  147.         FORMAT_MONEY1 OB.TOTAL_M_ALL_CH.0;
  148.     ELSE
  149.         FORMAT_MONEY2 OB.TOTAL_M_ALL_CH.2;
  150.     SUM_NET        = MTR_RESULT;
  151.  
  152.     IF w < 2 THEN
  153.         FORMAT_MONEY1 OB.TOTAL_M_ALL_CH.1;
  154.     ELSE
  155.         FORMAT_MONEY2 OB.TOTAL_M_ALL_CH.3;
  156.     SUM_GROSS    = MTR_RESULT;
  157.  
  158.  
  159.     ADDRESS VALUE WWPort;
  160.     OPEN FILENAME WWDokument FORCE;
  161.  
  162.     DruckString    = OB.OFFICE.ADDRESS.ADDRESS.2 || LF;
  163.     i = INDEX( DruckString, LF);
  164.     IF i > 0 THEN
  165.         DO;
  166.             DruckTeil    = LEFT( DruckString, (i - 1) );
  167.             DruckString = SUBSTR(DruckString, (i + 1) );
  168.             i = INDEX( DruckString, LF);
  169.         END;
  170.     ELSE
  171.         DruckTeil    = DruckString;
  172.     FINDCHANGE FIND "<OFFICE.ADDRESS.ADDRESS.2>" CHANGE DruckTeil;
  173.     DO WHILE( i > 0 );
  174.         DruckTeil    = LEFT( DruckString, (i - 1) );
  175.         DruckString = SUBSTR(DruckString, (i + 1) );
  176.         LINE 1;
  177.         TEXT DruckTeil;
  178.         i = INDEX( DruckString, LF);
  179.     END;
  180.  
  181.     POSITION SOV;
  182.     FINDCHANGE FIND "<PRINTDATE>" CHANGE PRINTDATE;
  183.     /* Leider wird bei längeren Texten der hintere Teil verschluckt, also nochmal ausgeben */
  184.     TEXT PRINTDATE;
  185.  
  186.     FINDCHANGE FIND "<OFFICE.ADDRESS.ADDRESS.0>" CHANGE OB.OFFICE.ADDRESS.ADDRESS.0;
  187.     /* Leider wird bei längeren Texten der hintere Teil verschluckt, also nochmal ausgeben */
  188.     TEXT OB.OFFICE.ADDRESS.ADDRESS.0;
  189.  
  190.     IF OB.INVOICEE_NUMBER = 0 THEN
  191.         FINDCHANGE FIND "<CUSTOMER.ADDRESS.ADDRESS.2>" CHANGE "Barverkauf";
  192.     ELSE
  193.         DO;
  194.             DruckString    = OB.INVOICEE.CUSTOMER.ADDRESS.ADDRESS.2 || LF;
  195.             i = INDEX( DruckString, LF);
  196.             IF i > 0 THEN
  197.                 DO;
  198.                     DruckTeil    = LEFT( DruckString, (i - 1) );
  199.                     DruckString = SUBSTR(DruckString, (i + 1) );
  200.                     i = INDEX( DruckString, LF);
  201.                 END;
  202.             ELSE
  203.                 DruckTeil    = DruckString;
  204.             FINDCHANGE FIND "<CUSTOMER.ADDRESS.ADDRESS.2>" CHANGE DruckTeil;
  205.             DO WHILE( i > 0 );
  206.                 DruckTeil    = LEFT( DruckString, (i - 1) );
  207.                 DruckString = SUBSTR(DruckString, (i + 1) );
  208.                 LINE 1;
  209.                 TEXT DruckTeil;
  210.                 i = INDEX( DruckString, LF);
  211.             END;
  212.         END;
  213.  
  214.     POSITION SOV;
  215.     FIND "<OB.CONSIGNEE.ADDRESS.ADDRESS.2>"
  216.     if OB.CONSIGNEE_NUMBER = 0 THEN
  217.         DO;
  218.             POSITION SOL;
  219.             SHIFTDOWN;
  220.             LINE 1;
  221.             SHIFTUP;
  222.             BACKSPACE;
  223.         END;
  224.     ELSE
  225.         DO;
  226.             j = 0;
  227.             DruckString    = OB.CONSIGNEE.CUSTOMER.ADDRESS.ADDRESS.2 || LF;
  228.             i = INDEX( DruckString, LF);
  229.             DO WHILE( i > 0 );
  230.                 DruckTeil    = LEFT( DruckString, (i - 1) );
  231.                 DruckString = SUBSTR(DruckString, (i + 1) );
  232.                 IF j > 0 THEN
  233.                     DO;
  234.                         NEWPARAGRAPH;
  235.                         TEXT "    ";
  236.                     END
  237.                 TEXT DruckTeil;
  238.                 i = INDEX( DruckString, LF);
  239.                 j = j + 1;
  240.             END;
  241.         END;
  242.  
  243.     FINDCHANGE FIND "<OB.INVOICEE_NUMBER>" CHANGE ZW_Kunde;
  244.     FINDCHANGE FIND "<OB.NUMBER>" CHANGE ZW_Rechnung;
  245.     FINDCHANGE FIND "<OB.DATE_TENDER>" CHANGE TENDER_DATE_LONG;
  246.     /* Leider wird bei längeren Texten der hintere Teil verschluckt, also nochmal ausgeben */
  247.     TEXT TENDER_DATE_LONG;
  248.     FINDCHANGE FIND "<OB.EMPLOYEE.SUR_PRENAME>" CHANGE (OB.EMPLOYEE.ADDRESS.PRENAME OB.EMPLOYEE.ADDRESS.SURNAME);
  249.  
  250.     FIND "<ARTICLE>";
  251.     BACKSPACE;
  252.  
  253.     DO i = 1 to OB.COUNT_ARTICLE;
  254.  
  255.         ADDRESS VALUE ARexxPort;
  256.  
  257.         ZW_ArtikelNr    = OB.i.POS_ARTICLE_NUMBER_FORMATED;
  258.  
  259.         FORMAT_NUMBER (OB.i.POS_QUANTITY / OB.i.POS_PRICE_UNIT) PREFS.FRAC_DIGITS;
  260.         ZW_Anzahl        = MTR_RESULT;
  261.  
  262.         NAME_OF_QUANTITY_UNIT OB.i.ARTICLE.QUANTITY_UNIT;
  263.         ZW_Einheit        = MTR_RESULT;
  264.  
  265.         j = OB.i.POS_VALUE;
  266.         FORMAT_NUMBER OB.VALUE_PERCENT.j PREFS.FRAC_DIGITS_PERCENT;
  267.         ZW_MWSt            = MTR_RESULT;
  268.  
  269.         ZW_Bezeichnung = OB.i.ARTICLE.DESCRIPTION;
  270.  
  271.         IF w < 2 THEN
  272.             FORMAT_MONEY1 OB.i.POS_SINGLE_PRICE.w;
  273.         ELSE
  274.             FORMAT_MONEY2 OB.i.POS_SINGLE_PRICE.w;
  275.         ZW_EinzelPreis    = MTR_RESULT;
  276.         
  277.         ADDRESS VALUE WWPort;
  278.  
  279.         TEXT ZW_ArtikelNr || "    " || ZW_Anzahl || "    " || ZW_Bezeichnung || "    " || ZW_Einheit || "    " || ZW_MWSt || "    " || ZW_EinzelPreis;
  280.  
  281.         IF OB.i.ARTICLE.ADDITIONAL_TEXT > "" THEN
  282.             DO;
  283.                 DruckString    = OB.i.ARTICLE.ADDITIONAL_TEXT || LF;
  284.                 i2 = INDEX( DruckString, LF);
  285.                 DO WHILE( i2 > 0 );
  286.                     DruckTeil    = LEFT( DruckString, (i2 - 1) );
  287.                     DruckString = SUBSTR(DruckString, (i2 + 1) );
  288.                     NEWPARAGRAPH;
  289.                     TEXT "        " || DruckTeil || "            ";
  290.                     i2 = INDEX( DruckString, LF);
  291.                 END;
  292.             END;
  293.  
  294.         IF OB.i.POS_REMARK > "" THEN
  295.             DO;
  296.                 DruckString    = OB.i.POS_REMARK || LF;
  297.                 i2 = INDEX( DruckString, LF);
  298.                 DO WHILE( i2 > 0 );
  299.                     DruckTeil    = LEFT( DruckString, (i2 - 1) );
  300.                     DruckString = SUBSTR(DruckString, (i2 + 1) );
  301.                     NEWPARAGRAPH;
  302.                     TEXT "        " || DruckTeil || "            ";
  303.                     i2 = INDEX( DruckString, LF);
  304.                 END;
  305.             END;
  306.  
  307.         DO i2 = 0 TO 2;
  308.             IF OB.i.POS_ADD_RED_USED.i2 > 0 THEN
  309.                 DO;
  310.                     ADDRESS VALUE ARexxPort;
  311.  
  312.                     j2 = OB.i.POS_ADD_RED_USED.i2 - 1;
  313.                     IF OB.i.POS_ADD_RED_TYPE.i2 = 0 | OB.i.POS_ADD_RED_TYPE.i2 = 5 THEN
  314.                         DO;
  315.                             FORMAT_NUMBER OB.i.POS_ADD_RED_VALUE.i2.w PREFS.FRAC_DIGITS_PERCENT;
  316.                         END;
  317.                     ELSE
  318.                         DO;
  319.                             IF w < 2 THEN
  320.                                 FORMAT_MONEY1 OB.i.POS_ADD_RED_VALUE.i2.w;
  321.                             ELSE
  322.                                 FORMAT_MONEY2 OB.i.POS_ADD_RED_VALUE.i2.w;
  323.                         END;
  324.                     ZW_EinzelZuAb    = RIGHT(MTR_RESULT, 15);
  325.  
  326.                     IF w < 2 THEN
  327.                         FORMAT_MONEY1 OB.i.POS_ADD_RED_VALUE_POS.i2.w;
  328.                     ELSE
  329.                         FORMAT_MONEY2 OB.i.POS_ADD_RED_VALUE_POS.i2.w;
  330.                     ZW_PosZuAb        = RIGHT(MTR_RESULT, 15);
  331.  
  332.                     ADDRESS VALUE WWPort;
  333.                     NEWPARAGRAPH;
  334.                     TEXT "        " || PREFS.ADD_RED_TEXT.j2 || "        " || ZW_EinzelZuAb || "    " || ZW_PosZuAb;
  335.                 E